<script setup>
	import { ref } from 'vue';
	import { onShow } from '@dcloudio/uni-app'
	import { getMemberAddressAPI, deleteMemberAddressByIdAPI } from '@/utils/apis.js'
	import { useMemberStore } from '@/stores/store.js'
	
	// 获取页面参数
	let query = defineProps({
		from: {
			type: String
		}
	})
	
	// 使用pinia
	const memberStore = useMemberStore()
	let onChangeAddress = (item) => {
		if(query.from == 'order'){
			// 预付订单页面过来 选择收货地址
			memberStore.changeSelecteAddress(item)
			uni.navigateBack()
		}
	}
	
	
	
	let addressList = ref([])
	let getMemberAddressData = async() => {
		let res = await getMemberAddressAPI()
		addressList.value = res.result
	}
	onShow(() => {
		getMemberAddressData()
	})
	
	// 删除地址
	let onDelAddress = (id) => {
		uni.showModal({
		    content: '删除地址?',
		    success: async (res) => {
				if (res.confirm) {
					// 根据id删除收货地址
					await deleteMemberAddressByIdAPI(id)
					// 这里加 await 是为了执行完删除在执行下面的
					// 重新获取收货地址列表
					getMemberAddressData()
				}
		    }
		})
	}
	
</script>

<template>
	<view class="viewport">
		<!-- 地址列表 -->
		<scroll-view class="scroll-view" scroll-y>
			<view v-if="addressList.length" class="address">
				<uni-swipe-action class="address-list">
					<!-- 收货地址项 -->
					<uni-swipe-action-item class="item" v-for="item in addressList" :key="item.id">
						<view class="item-content" @click="onChangeAddress(item)">
							<view class="user">
								{{ item.receiver }}
								<text class="contact">{{ item.contact }}</text>
								<text v-if="item.isDefault" class="badge">默认</text>
							</view>
							<view class="locate">{{ item.fullLocation }} {{ item.address }}</view>
							<!-- @click.stop 阻止事件冒泡 a链接和页面跳转事件  -->
							<navigator
								class="edit"
								hover-class="none"
								@click.stop="() => {}"
								:url="`/subpkg/addressForm/addressForm?id=${item.id}`"
							>修改</navigator>
						</view>
						<!-- 右侧插槽 -->
						<template #right>
						    <button @click="onDelAddress(item.id)" class="delete-button">删除</button>
						</template>
					</uni-swipe-action-item>
					<!-- 收货地址项 -->
				</uni-swipe-action>
			</view>
			<view v-else class="blank">暂无收货地址</view>
		</scroll-view>
		<!-- 添加按钮 -->
		<view class="add-btn">
			<navigator hover-class="none" url="/subpkg/addressForm/addressForm">
				新建地址
			</navigator>
		</view>
	</view>
</template>

<style lang="scss">
	page {
		height: 100%;
		overflow: hidden;
	}

	/* 删除按钮 */
	.delete-button {
		display: flex;
		justify-content: center;
		align-items: center;
		width: 50px;
		height: 100%;
		font-size: 28rpx;
		color: #fff;
		border-radius: 0;
		padding: 0;
		background-color: #cf4444;
	}

	.viewport {
		display: flex;
		flex-direction: column;
		height: 100%;
		background-color: #f4f4f4;

		.scroll-view {
			padding-top: 20rpx;
		}
	}

	.address {
		padding: 0 20rpx;
		margin: 0 20rpx;
		border-radius: 10rpx;
		background-color: #fff;

		.item-content {
			line-height: 1;
			padding: 40rpx 10rpx 38rpx;
			border-bottom: 1rpx solid #ddd;
			position: relative;

			.edit {
				position: absolute;
				top: 36rpx;
				right: 30rpx;
				padding: 2rpx 0 2rpx 20rpx;
				border-left: 1rpx solid #666;
				font-size: 26rpx;
				color: #666;
				line-height: 1;
			}
		}

		.item:last-child .item-content {
			border: none;
		}

		.user {
			font-size: 28rpx;
			margin-bottom: 20rpx;
			color: #333;

			.contact {
				color: #666;
			}

			.badge {
				display: inline-block;
				padding: 4rpx 10rpx 2rpx 14rpx;
				margin: 2rpx 0 0 10rpx;
				font-size: 26rpx;
				color: #27ba9b;
				border-radius: 6rpx;
				border: 1rpx solid #27ba9b;
			}
		}

		.locate {
			line-height: 1.6;
			font-size: 26rpx;
			color: #333;
		}
	}

	.blank {
		margin-top: 300rpx;
		text-align: center;
		font-size: 32rpx;
		color: #888;
	}

	.add-btn {
		height: 80rpx;
		text-align: center;
		line-height: 80rpx;
		margin: 30rpx 20rpx;
		color: #fff;
		border-radius: 80rpx;
		font-size: 30rpx;
		background-color: #27ba9b;
	}
</style>